home *** CD-ROM | disk | FTP | other *** search
/ PC World 2006 July & August / PCWorld_2006-07-08_cd.bin / komunikace / apache / apache_2[1].2.2-win32-x86-no_ssl.msi / Data1.cab / _45B2F8A71909E28786C6F9DD98083B7A < prev    next >
Extensible Markup Language  |  2006-04-07  |  17KB  |  263 lines

  1. <?xml version="1.0" encoding="ISO-8859-1"?>
  2. <!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Strict//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-strict.dtd">
  3. <html xmlns="http://www.w3.org/1999/xhtml" lang="en" xml:lang="en"><head><!--
  4.         XXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXX
  5.               This file is generated from xml source: DO NOT EDIT
  6.         XXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXX
  7.       -->
  8. <title>mod_dbd - Apache HTTP Server</title>
  9. <link href="../style/css/manual.css" rel="stylesheet" media="all" type="text/css" title="Main stylesheet" />
  10. <link href="../style/css/manual-loose-100pc.css" rel="alternate stylesheet" media="all" type="text/css" title="No Sidebar - Default font size" />
  11. <link href="../style/css/manual-print.css" rel="stylesheet" media="print" type="text/css" />
  12. <link href="../images/favicon.ico" rel="shortcut icon" /></head>
  13. <body>
  14. <div id="page-header">
  15. <p class="menu"><a href="../mod/">Modules</a> | <a href="../mod/directives.html">Directives</a> | <a href="../faq/">FAQ</a> | <a href="../glossary.html">Glossary</a> | <a href="../sitemap.html">Sitemap</a></p>
  16. <p class="apache">Apache HTTP Server Version 2.2</p>
  17. <img alt="" src="../images/feather.gif" /></div>
  18. <div class="up"><a href="./"><img title="<-" alt="<-" src="../images/left.gif" /></a></div>
  19. <div id="path">
  20. <a href="http://www.apache.org/">Apache</a> > <a href="http://httpd.apache.org/">HTTP Server</a> > <a href="http://httpd.apache.org/docs/">Documentation</a> > <a href="../">Version 2.2</a> > <a href="./">Modules</a></div>
  21. <div id="page-content">
  22. <div id="preamble"><h1>Apache Module mod_dbd</h1>
  23. <div class="toplang">
  24. <p><span>Available Languages: </span><a href="../en/mod/mod_dbd.html" title="English"> en </a></p>
  25. </div>
  26. <table class="module"><tr><th><a href="module-dict.html#Description">Description:</a></th><td>Manages SQL database connections</td></tr>
  27. <tr><th><a href="module-dict.html#Status">Status:</a></th><td>Extension</td></tr>
  28. <tr><th><a href="module-dict.html#ModuleIdentifier">ModuleáIdentifier:</a></th><td>dbd_module</td></tr>
  29. <tr><th><a href="module-dict.html#SourceFile">SourceáFile:</a></th><td>mod_dbd.c</td></tr>
  30. <tr><th><a href="module-dict.html#Compatibility">Compatibility:</a></th><td>Version 2.1 and later</td></tr></table>
  31. <h3>Summary</h3>
  32.  
  33.     <p><code class="module"><a href="../mod/mod_dbd.html">mod_dbd</a></code> manages SQL database connections using
  34.     <a href="http://people.apache.org/~niq/dbd.html">apr_dbd</a>.
  35.     It provides database connections on request to modules
  36.     requiring SQL database functions, and takes care of
  37.     managing databases with optimal efficiency and scalability
  38.     for both threaded and non-threaded MPMs.</p>
  39. </div>
  40. <div id="quickview"><h3 class="directives">Directives</h3>
  41. <ul id="toc">
  42. <li><img alt="" src="../images/down.gif" /> <a href="#dbdexptime">DBDExptime</a></li>
  43. <li><img alt="" src="../images/down.gif" /> <a href="#dbdkeep">DBDKeep</a></li>
  44. <li><img alt="" src="../images/down.gif" /> <a href="#dbdmax">DBDMax</a></li>
  45. <li><img alt="" src="../images/down.gif" /> <a href="#dbdmin">DBDMin</a></li>
  46. <li><img alt="" src="../images/down.gif" /> <a href="#dbdparams">DBDParams</a></li>
  47. <li><img alt="" src="../images/down.gif" /> <a href="#dbdpersist">DBDPersist</a></li>
  48. <li><img alt="" src="../images/down.gif" /> <a href="#dbdpreparesql">DBDPrepareSQL</a></li>
  49. <li><img alt="" src="../images/down.gif" /> <a href="#dbdriver">DBDriver</a></li>
  50. </ul>
  51. <h3>Topics</h3>
  52. <ul id="topics">
  53. <li><img alt="" src="../images/down.gif" /> <a href="#pooling">Connection Pooling</a></li>
  54. <li><img alt="" src="../images/down.gif" /> <a href="#API">Apache DBD API</a></li>
  55. <li><img alt="" src="../images/down.gif" /> <a href="#prepared">SQL Prepared Statements</a></li>
  56. </ul></div>
  57. <div class="top"><a href="#page-header"><img alt="top" src="../images/up.gif" /></a></div>
  58. <div class="section">
  59. <h2><a name="pooling" id="pooling">Connection Pooling</a></h2>
  60.     <p>This module manages database connections, in a manner
  61.     optimised for the platform.  On non-threaded platforms,
  62.     it provides a persistent connection in the manner of
  63.     classic LAMP (Linux, Apache, Mysql, Perl/PHP/Python).
  64.     On threaded platform, it provides an altogether more
  65.     scalable and efficient <em>connection pool</em>, as
  66.     described in <a href="http://www.apachetutor.org/dev/reslist">this article at ApacheTutor</a>. <code class="module"><a href="../mod/mod_dbd.html">mod_dbd</a></code> supersedes
  67.     the modules presented in that article.</p>
  68. </div><div class="top"><a href="#page-header"><img alt="top" src="../images/up.gif" /></a></div>
  69. <div class="section">
  70. <h2><a name="API" id="API">Apache DBD API</a></h2>
  71.     <p><code class="module"><a href="../mod/mod_dbd.html">mod_dbd</a></code> exports five functions for other modules
  72.     to use. The API is as follows:</p>
  73.  
  74.     <div class="example"><pre><code>typedef struct {
  75.     apr_dbd_t *handle;
  76.     apr_dbd_driver_t *driver;
  77.     apr_hash_t *prepared;
  78. } ap_dbd_t;
  79.  
  80. /* Export functions to access the database */
  81.  
  82. /* acquire a connection that MUST be explicitly closed.
  83.  * Returns NULL on error
  84.  */
  85. AP_DECLARE(ap_dbd_t*) ap_dbd_open(apr_pool_t*, server_rec*);
  86.  
  87. /* release a connection acquired with ap_dbd_open */
  88. AP_DECLARE(void) ap_dbd_close(server_rec*, ap_dbd_t*);
  89.  
  90. /* acquire a connection that will have the lifetime of a request
  91.  * and MUST NOT be explicitly closed.  Return NULL on error.
  92.  * This is the preferred function for most applications.
  93.  */
  94. AP_DECLARE(ap_dbd_t*) ap_dbd_acquire(request_rec*);
  95.  
  96. /* acquire a connection that will have the lifetime of a connection
  97.  * and MUST NOT be explicitly closed.  Return NULL on error.
  98.  */
  99. AP_DECLARE(ap_dbd_t*) ap_dbd_cacquire(request_rec*);
  100.  
  101. /* Prepare a statement for use by a client module */
  102. AP_DECLARE(void) ap_dbd_prepare(server_rec*, const char*, const char*);
  103.  
  104. /* Also export them as optional functions for modules that prefer it */
  105. APR_DECLARE_OPTIONAL_FN(ap_dbd_t*, ap_dbd_open, (apr_pool_t*, server_rec*));
  106. APR_DECLARE_OPTIONAL_FN(void, ap_dbd_close, (server_rec*, ap_dbd_t*));
  107. APR_DECLARE_OPTIONAL_FN(ap_dbd_t*, ap_dbd_acquire, (request_rec*));
  108. APR_DECLARE_OPTIONAL_FN(ap_dbd_t*, ap_dbd_cacquire, (conn_rec*));
  109. APR_DECLARE_OPTIONAL_FN(void, ap_dbd_prepare, (server_rec*, const char*, const char*));
  110. </code></pre></div>
  111. </div><div class="top"><a href="#page-header"><img alt="top" src="../images/up.gif" /></a></div>
  112. <div class="section">
  113. <h2><a name="prepared" id="prepared">SQL Prepared Statements</a></h2>
  114.     <p><code class="module"><a href="../mod/mod_dbd.html">mod_dbd</a></code> supports SQL prepared statements on behalf
  115.     of modules that may wish to use them.  Each prepared statement
  116.     must be assigned a name (label), and they are stored in a hash:
  117.     the <code>prepared</code> field of an <code>ap_dbd_t</code>.
  118.     Hash entries are of type <code>apr_dbd_prepared_t</code>
  119.     and can be used in any of the apr_dbd prepared statement
  120.     SQL query or select commands.</p>
  121.  
  122.     <p>It is up to dbd user modules to use the prepared statements
  123.     and document what statements can be specified in httpd.conf,
  124.     or to provide their own directives and use <code>ap_dbd_prepare</code>.</p>
  125. </div>
  126. <div class="top"><a href="#page-header"><img alt="top" src="../images/up.gif" /></a></div>
  127. <div class="directive-section"><h2><a name="DBDExptime" id="DBDExptime">DBDExptime</a> <a name="dbdexptime" id="dbdexptime">Directive</a></h2>
  128. <table class="directive">
  129. <tr><th><a href="directive-dict.html#Description">Description:</a></th><td>Keepalive time for idle connections</td></tr>
  130. <tr><th><a href="directive-dict.html#Syntax">Syntax:</a></th><td><code>DBDExptime <var>time-in-seconds</var></code></td></tr>
  131. <tr><th><a href="directive-dict.html#Context">Context:</a></th><td>server config, virtual host</td></tr>
  132. <tr><th><a href="directive-dict.html#Status">Status:</a></th><td>Extension</td></tr>
  133. <tr><th><a href="directive-dict.html#Module">Module:</a></th><td>mod_dbd</td></tr>
  134. </table>
  135.     <p>Set the time to keep idle connections alive where the number
  136.     of connections specified in DBDKeep has been exceeded (threaded
  137.     platforms only).</p>
  138.  
  139. </div>
  140. <div class="top"><a href="#page-header"><img alt="top" src="../images/up.gif" /></a></div>
  141. <div class="directive-section"><h2><a name="DBDKeep" id="DBDKeep">DBDKeep</a> <a name="dbdkeep" id="dbdkeep">Directive</a></h2>
  142. <table class="directive">
  143. <tr><th><a href="directive-dict.html#Description">Description:</a></th><td>Maximum sustainednumber of connections</td></tr>
  144. <tr><th><a href="directive-dict.html#Syntax">Syntax:</a></th><td><code>DBDKeep <var>number</var></code></td></tr>
  145. <tr><th><a href="directive-dict.html#Context">Context:</a></th><td>server config, virtual host</td></tr>
  146. <tr><th><a href="directive-dict.html#Status">Status:</a></th><td>Extension</td></tr>
  147. <tr><th><a href="directive-dict.html#Module">Module:</a></th><td>mod_dbd</td></tr>
  148. </table>
  149.     <p>Set the maximum number of connections per process to be
  150.     sustained, other than for handling peak demand (threaded
  151.     platforms only).</p>
  152.  
  153. </div>
  154. <div class="top"><a href="#page-header"><img alt="top" src="../images/up.gif" /></a></div>
  155. <div class="directive-section"><h2><a name="DBDMax" id="DBDMax">DBDMax</a> <a name="dbdmax" id="dbdmax">Directive</a></h2>
  156. <table class="directive">
  157. <tr><th><a href="directive-dict.html#Description">Description:</a></th><td>Maximum number of connections</td></tr>
  158. <tr><th><a href="directive-dict.html#Syntax">Syntax:</a></th><td><code>DBDMax <var>number</var></code></td></tr>
  159. <tr><th><a href="directive-dict.html#Context">Context:</a></th><td>server config, virtual host</td></tr>
  160. <tr><th><a href="directive-dict.html#Status">Status:</a></th><td>Extension</td></tr>
  161. <tr><th><a href="directive-dict.html#Module">Module:</a></th><td>mod_dbd</td></tr>
  162. </table>
  163.     <p>Set the hard maximum number of connections per process
  164.     (threaded platforms only).</p>
  165.  
  166. </div>
  167. <div class="top"><a href="#page-header"><img alt="top" src="../images/up.gif" /></a></div>
  168. <div class="directive-section"><h2><a name="DBDMin" id="DBDMin">DBDMin</a> <a name="dbdmin" id="dbdmin">Directive</a></h2>
  169. <table class="directive">
  170. <tr><th><a href="directive-dict.html#Description">Description:</a></th><td>Minimum number of connections</td></tr>
  171. <tr><th><a href="directive-dict.html#Syntax">Syntax:</a></th><td><code>DBDMin <var>number</var></code></td></tr>
  172. <tr><th><a href="directive-dict.html#Context">Context:</a></th><td>server config, virtual host</td></tr>
  173. <tr><th><a href="directive-dict.html#Status">Status:</a></th><td>Extension</td></tr>
  174. <tr><th><a href="directive-dict.html#Module">Module:</a></th><td>mod_dbd</td></tr>
  175. </table>
  176.     <p>Set the minimum number of connections per process (threaded
  177.     platforms only).</p>
  178.  
  179. </div>
  180. <div class="top"><a href="#page-header"><img alt="top" src="../images/up.gif" /></a></div>
  181. <div class="directive-section"><h2><a name="DBDParams" id="DBDParams">DBDParams</a> <a name="dbdparams" id="dbdparams">Directive</a></h2>
  182. <table class="directive">
  183. <tr><th><a href="directive-dict.html#Description">Description:</a></th><td>Parameters for database connection</td></tr>
  184. <tr><th><a href="directive-dict.html#Syntax">Syntax:</a></th><td><code>DBDParams
  185. <var>param1</var>=<var>value1</var>[,<var>param2</var>=<var>value2</var>]</code></td></tr>
  186. <tr><th><a href="directive-dict.html#Context">Context:</a></th><td>server config, virtual host</td></tr>
  187. <tr><th><a href="directive-dict.html#Status">Status:</a></th><td>Extension</td></tr>
  188. <tr><th><a href="directive-dict.html#Module">Module:</a></th><td>mod_dbd</td></tr>
  189. </table>
  190.     <p>As required by the underlying driver.  Typically this will be
  191.     used to pass whatever cannot be defaulted amongst username,
  192.     password, database name, hostname and port number for connection.</p>
  193.     <p>Connection string parameters for current drivers include:</p>
  194.     <dl>
  195.     <dt>MySQL</dt>
  196.     <dd>host, port, user, pass, dbname, sock</dd> 
  197.     <dt>Oracle</dt>
  198.     <dd>user, pass, dbname, server</dd> 
  199.     <dt>PostgreSQL</dt>
  200.     <dd>The connection string is passed straight through to <code>PQconnectdb</code></dd>
  201.     <dt>SQLite2</dt>
  202.     <dd>The connection string is split on a colon, and <code>part1:part2</code> is used as <code>sqlite_open(part1, atoi(part2), NULL)</code></dd>
  203.     <dt>SQLite3</dt>
  204.     <dd>The connection string is passed straight through to <code>sqlite3_open</code></dd>
  205.     </dl>
  206.  
  207. </div>
  208. <div class="top"><a href="#page-header"><img alt="top" src="../images/up.gif" /></a></div>
  209. <div class="directive-section"><h2><a name="DBDPersist" id="DBDPersist">DBDPersist</a> <a name="dbdpersist" id="dbdpersist">Directive</a></h2>
  210. <table class="directive">
  211. <tr><th><a href="directive-dict.html#Description">Description:</a></th><td>Whether to use persistent connections</td></tr>
  212. <tr><th><a href="directive-dict.html#Syntax">Syntax:</a></th><td><code>DBDPersist 0|1</code></td></tr>
  213. <tr><th><a href="directive-dict.html#Context">Context:</a></th><td>server config, virtual host</td></tr>
  214. <tr><th><a href="directive-dict.html#Status">Status:</a></th><td>Extension</td></tr>
  215. <tr><th><a href="directive-dict.html#Module">Module:</a></th><td>mod_dbd</td></tr>
  216. </table>
  217.     <p>If set to 0, persistent and pooled connections are disabled.
  218.     A new database connection is opened when requested by a client,
  219.     and closed immediately on release.  This option is for debugging
  220.     and low-usage servers.</p>
  221.  
  222.     <p>The default is to enable a pool of persistent connections
  223.     (or a single LAMP-style persistent connection in the case of a
  224.     non-threaded server), and should almost always be used in operation.</p>
  225.  
  226. </div>
  227. <div class="top"><a href="#page-header"><img alt="top" src="../images/up.gif" /></a></div>
  228. <div class="directive-section"><h2><a name="DBDPrepareSQL" id="DBDPrepareSQL">DBDPrepareSQL</a> <a name="dbdpreparesql" id="dbdpreparesql">Directive</a></h2>
  229. <table class="directive">
  230. <tr><th><a href="directive-dict.html#Description">Description:</a></th><td>Define an SQL prepared statement</td></tr>
  231. <tr><th><a href="directive-dict.html#Syntax">Syntax:</a></th><td><code>DBDPrepareSQL <var>"SQL statement"</var> <var>label</var></code></td></tr>
  232. <tr><th><a href="directive-dict.html#Context">Context:</a></th><td>server config, virtual host</td></tr>
  233. <tr><th><a href="directive-dict.html#Status">Status:</a></th><td>Extension</td></tr>
  234. <tr><th><a href="directive-dict.html#Module">Module:</a></th><td>mod_dbd</td></tr>
  235. </table>
  236.     <p>For modules such as authentication that use repeatedly use a
  237.     single SQL statement, optimum performance is achieved by preparing
  238.     the statement at startup rather than every time it is used.
  239.     This directive prepares an SQL statement and assigns it a label.</p>
  240.  
  241. </div>
  242. <div class="top"><a href="#page-header"><img alt="top" src="../images/up.gif" /></a></div>
  243. <div class="directive-section"><h2><a name="DBDriver" id="DBDriver">DBDriver</a> <a name="dbdriver" id="dbdriver">Directive</a></h2>
  244. <table class="directive">
  245. <tr><th><a href="directive-dict.html#Description">Description:</a></th><td>Specify an SQL driver</td></tr>
  246. <tr><th><a href="directive-dict.html#Syntax">Syntax:</a></th><td><code>DBDriver <var>name</var></code></td></tr>
  247. <tr><th><a href="directive-dict.html#Context">Context:</a></th><td>server config, virtual host</td></tr>
  248. <tr><th><a href="directive-dict.html#Status">Status:</a></th><td>Extension</td></tr>
  249. <tr><th><a href="directive-dict.html#Module">Module:</a></th><td>mod_dbd</td></tr>
  250. </table>
  251.     <p>Selects an apr_dbd driver by name.  The driver must be installed
  252.     on your system (on most systems, it will be a shared object or dll).
  253.     For example, <code>DBDriver mysql</code> will select the MySQL
  254.     driver in apr_dbd_mysql.so.</p>
  255.  
  256. </div>
  257. </div>
  258. <div class="bottomlang">
  259. <p><span>Available Languages: </span><a href="../en/mod/mod_dbd.html" title="English"> en </a></p>
  260. </div><div id="footer">
  261. <p class="apache">Copyright 1995-2006 The Apache Software Foundation or its licensors, as applicable.<br />Licensed under the <a href="http://www.apache.org/licenses/LICENSE-2.0">Apache License, Version 2.0</a>.</p>
  262. <p class="menu"><a href="../mod/">Modules</a> | <a href="../mod/directives.html">Directives</a> | <a href="../faq/">FAQ</a> | <a href="../glossary.html">Glossary</a> | <a href="../sitemap.html">Sitemap</a></p></div>
  263. </body></html>